<template>
	<view class="wrapForm">
		<view class="bgLine flex jst-between pL25 pR25 pT20 pB20"></view>

		<view class="wrapFormBody pL15 pR15 pT15 rzBox">
			<u-form  :label-width="200" :error-type="['toast']" :label-style="{'font-size':'30rpx'}" class="xf-wrap-form"
				ref="dataForm" :rules="rules" :model="formData">
				
				<u-form-item :required="true" label="企业名称" :label-position="'top'" prop="comName">
					<u-input class="t-right" placeholder="请输入企业名称" v-model="formData.comName" />
				</u-form-item>
				<u-form-item :required="true" label="企业统一信用代码" :label-position="'top'" prop="comCode">
					<view class="w100 flex alg-center jst-between">
						<u-input class="t-right" placeholder="请输入企业统一信用代码" v-model="formData.comCode" />
					</view>
				</u-form-item>
				<u-form-item :required="true" label="联系人" :label-position="'top'" prop="comContacts">
					<view class="w100 flex alg-center jst-between">
						<u-input class="t-right" placeholder="请输入联系人" v-model="formData.comContacts" />
					</view>
				</u-form-item>
				<u-form-item :required="true" label="联系电话" :label-position="'top'" prop="comContactsPhone">
					<view class="w100 flex alg-center jst-between">
						<u-input class="t-right" placeholder="请输入联系电话" v-model="formData.comContactsPhone" />
					</view>
				</u-form-item>
				<u-form-item :required="true" label="身份证号" :label-position="'top'" prop="comContactsIdcard">
					<view class="w100 ">
						<u-input class="t-right" placeholder="请输入身份证号" v-model="formData.comContactsIdcard" />
					</view>
				</u-form-item>
				<u-form-item :required="true" label="企业地址" :label-position="'top'" prop="address">
					<view class="w100 flex alg-center jst-between">
						<view class="w70"><u-input :disabled="true" class="t-right" placeholder="请选择地址"
								v-model="formData.address" />
						</view>
						<image @click="chooseLocation" class="imgW36" :src="resources.posIcon" mode=""></image>
					</view>
				</u-form-item>
				<u-form-item :required="true" label="详细地址" :label-position="'top'" prop="comBelongAddress">
					<view class="w100 ">
						<u-input class="t-right" placeholder="请输入详细地址" v-model="formData.comBelongAddress" />
					</view>
				</u-form-item>
				<u-form-item :required="true" label="所属驿站" :label-position="'top'" prop="organizationName">
					<view class="w100 ">
						<u-input type="select" class="t-right" placeholder="请选择所属驿站" v-model="formData.organizationName"
							@click="showPicker" />
					</view>
				</u-form-item>
				
			</u-form>
			
		</view>
		<view class="flex jst-center  bottomFixed pT15 pB15 bgf">
			<view class="pointer rightNowPay u-f font15 t-center" @click="saveMyInfo">
				保存
			</view>
		</view>
		<xfTreePicker :defalutValue="formData.organizationId" :selectParent="false" ref="treePicker" :multiple="false"
			@select-change="selectChange" title="所属驿站" :localdata="deptLis" valueKey="id" textKey="name"
			codeKey="orgCode" childrenKey="children"></xfTreePicker>
	</view>
</template>

<script>
	import {comPanyInfoEdit,comPanyFeedback} from "@/api/economicInterface/user.js"
	import {getOrgTree} from "@/api/common.js"
	import selAreaMinxs from "@/utils/selArea.js"
	import {
		chooseLocal
	} from "@/libs/map.js"
	export default {
		mixins: [selAreaMinxs],
		data() {
			return {
				current:0,
				formData: {
					"comName": "",
					"comBelongAddress": "",
					"comCode": "",
					"comContactsIdcard": "",
					"comBusinessLicense": "",
					"comLongitude": "",
					"comLatitude": "",
					"provinceId": "",
					organizationName: "",
					organizationId: "",
					"provinceName": "",
					comContacts: "",
					comContactsPhone: "",
					"cityId": "",
					"cityName": "",
					"areaId": "",
					"areaName": "",
					address: ""
				},
				deptLis: [],
				rules: {
					comName: [{
						required: true,
						message: '请输入企业名称',
						trigger: ['change', 'blur'],
					}],
					comCode: [{
						required: true,
						message: '请输入统一信用代码',
						trigger: ['change', 'blur'],
					}, {
						pattern: /^[a-zA-Z0-9]+$/,
						message: '统一信用代码格式不正确',
						trigger: ['change', 'blur'],
					}],
					comContacts: [{
						required: true,
						message: '请输入联系人姓名',
						trigger: ['change', 'blur'],
					}],
					comContactsPhone: [{
						required: true,
						message: '联系电话不能为空',
						trigger: ['change', 'blur']
					}, {
						pattern: /^1[3456789]\d{9}$/,
						message: '手机号格式不正确',
						trigger: ['change', 'blur']
					}],
					address: [{
						required: true,
						message: '请选择企业地址',
						trigger: ['change', 'blur'],
					}],
					comBelongAddress: [{
						required: true,
						message: '请输入详细地址',
						trigger: ['change', 'blur'],
					}],
					
					comContactsIdcard: [{
						required: true,
						message: '请输入身份证号',
						trigger: ['change', 'blur'],
					}, {
						rule: /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X|x)$/,
						msg: '请正确输入您的身份证号码15-18位'
					}],
					organizationName: [{
						required: true,
						message: '请选择所属服务站点',
						trigger: ['change', 'blur'],
					}]
				}
			
			}
		},
		onReady() {
			this.$refs.dataForm.setRules(this.rules);
			this.getTreeOpt()
		},
		onLoad(e) {
			this.getCompanyInfoOpt(e.id)
		},
		methods: {
			showPicker() {
				this.$refs.treePicker._show();
			},
			//获取企业详情
			 getCompanyInfoOpt(id) {
				comPanyFeedback({
					id: id
				}).then(res => {
					let info = res.result;
					this.formData = {
						"id": info.id,
						"comName": info.comName,
						 comCode:info.comCode,
						 comContactsIdcard:info.comContactsIdcard,
						 comContacts:info.comContacts,
						 comContactsPhone:info.comContactsPhone,
						"comBelongAddress": info.comBelongAddress,
						organizationName: info.organizationName,
						organizationId: info.organizationId,
						"provinceId": info.provinceId,
						"provinceName": info.provinceName,
						"cityId": info.cityId,
						"cityName": info.cityName,
						"areaId": info.areaId,
						"areaName": info.areaName,
						comLatitude: info?.comLatitude||'',
						comLongitude: info?.comLongitude||'',
					}
					this.formData.address = this.formData.provinceName + this.formData.cityName + this.formData
						.areaName
					
					
				})
			},
			//监听选择（ids为数组）
			selectChange(ids, code, names) {
				if(this.current==0){
					this.formData.organizationName = names;
					this.formData.organizationId = ids;
				}else{
					this.personForm.organizationName = names;
					this.personForm.organizationId = ids;
				}
				

			},
			async chooseLocation() {
				let res = await chooseLocal();
				let r = res.address + res.name;
				let d = this.regionDiscern(r)
				this.formData.provinceId = d.data.province.code;
				this.formData.cityId = d.data.city.code;
				this.formData.areaId = d.data.area.code;
				this.formData.provinceName = d.data.province.name;
				this.formData.cityName = d.data.city.name;
				this.formData.areaName = d.data.area.name;
				this.formData.address = this.formData.provinceName + this.formData.cityName + this.formData.areaName
				this.formData.comLatitude = res.latitude;
				this.formData.comLongitude = res.longitude;
				this.formData.comBelongAddress = d.data.address;


			},
			getTreeOpt() {
				getOrgTree().then(res => {
					this.deptLis = res.result[0].children;
				})
			},
			saveMyInfo() {
				let data = this.xf.deepClone(this.formData)
				console.log(data)
				delete data.address
				this.$refs.dataForm.validate(async valid => {
					if(valid){
						comPanyInfoEdit(data).then(res=>{
							this.xf.onlineUtils.toast("修改成功!")
							setTimeout(() => {
								uni.navigateBack()
							}, 2000)
						})
					}
				})
				
			}
		}
	}
</script>
<style lang="scss">
	page {
		height: 100%;
		background-color: #fff;
	}

	.wrapFormBody {
		padding-bottom: 200rpx;

		.reasonBox {
			.u-input {
				border-radius: 20rpx !important;
			}
		}
	}
</style>
<style lang="scss" scoped>
	.wrapForm {
		.sfSelItem {

			background: #F8F8F8;
			border-radius: 20rpx;
			padding: 20rpx 30rpx;
			border: 2rpx solid transparent;
			color: #8d8d8d;

			&.active {
				border-radius: 20rpx;
				border: 2px solid #00A0C6;
				background: #EBFCFF;
				color: #00A0C6;
			}


		}

		.rzCardBox {

			height: 128rpx;
			background: #F8F8F8;
			border-radius: 16rpx 16rpx 16rpx 16rpx;
			margin-top: 60rpx;

			&:last-child {
				margin-top: 30rpx;
			}

			.imgRzCard {
				width: 40rpx;
				height: 32rpx;
			}
		}

		height: 100%;
		padding-bottom: 100rpx;

		.wrapFormBody {
			margin-top: -30rpx;
			border-radius: 40rpx 40rpx 0 0;
			background: #fff;
		}

		.uni-forms-item {
			align-items: center !important;
		}

		.uni-input-placeholder {
			text-align: left !important;
			color: #BDBDBD !important;
		}
	}

	.bgLine {
		background-color: #EBFCFF;
		width: 100%;
		// height: 60rpx;
		padding: 30rpx 40rpx;

		.rzImg {
			width: 168rpx;
			height: 192rpx;
		}
	}


	.rightNowPay {
		width: 670rpx;
		height: 100rpx;
		line-height: 100rpx;
		background: #00A0C6;
		border-radius: 30rpx;

	}
</style>